.flex {
  display: flex;
  align-items: center;
}
[v-cloak] {
  display: none;
}
* {
  margin: 0;
  padding: 0;
  border: none;
  outline: none;
  text-decoration: none;
}
.wrapper {
  min-height: 100vh;
  background: rgb(243, 251, 255);
}
.top {
  width: 100%;
  height: 11.467rem;
  -webkit-background-size: cover;
  background-size: cover;
  overflow: hidden;
  img {
    display: block;
    margin: 0.933rem auto;
    width: 8.173rem;
  }
}
.login-content {
  transform: translateY(-3.467rem);
  position: relative;
  margin: 0 0.533rem;
  padding: 0.933rem;
  background-color: #ffffff;
  box-shadow: 0rem 0.053rem 0.4rem 0rem
  rgba(41, 128, 232, 0.1);
  border-radius: 0.133rem;
  .label {
    margin-bottom: 0.4rem;
    padding: 0.2rem 0;
    display: flex;
    align-items: center;
    border-bottom: solid 0.027rem #e0e9ff;
    input {
      padding: 0 0.267rem;
      font-size: 0.427rem;
      color: #7b8197;
      width: 4.5rem;
    }
    .get-code {
      align-items: center;
      display: flex;
      justify-content: center;
      width: 2.427rem;
      height: 1.067rem;
      background-color: #1958d6;
      border-radius: 0.133rem;
      color: #fff;
      font-size: 0.33rem;
      font-weight: normal;
      font-stretch: normal;
    }
  }
  .login-btn {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    bottom: -0.667rem;
    .flex;
    justify-content: center;
    width: 6.267rem;
    height: 1.333rem;
    background-image: linear-gradient(225deg,
    #2b78ee 0%,
    #1f63de 50%,
    #1958d5 75%,
    #134dcd 100%);
    border-radius: 0.667rem;
    font-family: SourceHanSansSC-Regular;
    font-size: 0.48rem;
    color: #ffffff;
  }
  img {
    width: 0.427rem;
  }
}
.login-by-code {
  width: 100%;
  left: 0;
  position: absolute;
  bottom: 0.933rem;
  text-align: center;
  font-size: 0.373rem;
  color: #144fce;
}
.modal {
  position: fixed;
  width: 100%;
  height: 100vh;
  left: 0;
  top: 0;
  z-index: 2;
  background: rgba(0, 0, 0, .3);
  .modal-content {
    padding: 0.533rem 0.6rem;
    border-top: 0.093rem solid #53b0fc;
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translateX(-50%) translateY(-50%);
    width: 8.533rem;
    background-color: #ffffff;
    border-radius: 0.107rem;
    .title {
      margin-bottom: 0.507rem;
      .flex;
      justify-content: space-between;
      font-weight: 500;
      font-size: 0.4rem;
      color: #333333;
      line-height: 2;
      img {
        width: 0.667rem;
        height: 0.667rem;
        opacity: 0.47;
      }
    }
    .content {
      font-size: 0.347rem;
      font-weight: 500;
      color: #767676;
    }
  }
  /deep/ .modal-footer {
    .flex;
    justify-content: center;
    .btn {
      .flex;
      justify-content: center;
      width: 3.147rem;
      height: 0.933rem;
      background-image: linear-gradient(80deg,
      #58adff 0%,
      #1dd5da 100%),
      linear-gradient(
              #34c6c6,
              #34c6c6);
      background-blend-mode: normal,
      normal;
      box-shadow: 0.08rem 0.053rem 0.16rem 0rem
      rgba(47, 185, 189, 0.31);
      border-radius: 0.467rem;
      font-family: SourceHanSansCN-Regular;
      font-size: 0.32rem;
      color: #ffffff;
    }
  }
}

.fade-enter-active, .fade-leave-active {
  transition: opacity .2s ease;
}
.fade-enter, .fade-leave-active {
  opacity: 0;
}
